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Listing of Claims 

1 . (Previously Presented) A method for restoring a virtual path in an optical 
network, the method comprising: 

identifying a plurality of nodes with resources, wherein said nodes with resources 

are ones of said nodes having a resource necessary to support said virtual 

path; and 

identifying an alternate physical path in response to said identifying said plurality 
of nodes with resources, said alternate physical path comprising ones of 
said nodes with resources. 



2. (Original) The method of claim 1, further comprising: 

restoring said virtual path using said alternate physical path. 



3. (Original) The method of claim 2, wherein said restoring is done by 
configuring said alternate physical path by establishing a communication 

connection between said ones of said nodes with resources; and 
provisioning said virtual path over said alternate physical path. 

4. (Previously Presented) The method of claim 2, further comprising: 
detecting a failure in said virtual path; 

said detection of said failure is done by receiving a failure message packet; 
said virtual path is provisioned on a physical path between a first and a second 

node of said optical network; 
said optical network comprises said nodes; 

each one of said nodes is coupled to at least one other of said nodes by a plurality 
of optical links; 

said physical path between said first and said second node comprises a plurality of 

intermediate nodes; and 
each one of said nodes is coupled to at least one other of said nodes in a mesh 

topology. 
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5. (Original) The method of claim 4, wherein said restoring of said virtual path is 
completed in less than 2 seconds. 

6. (Original) The method of claim 4, wherein said restoring of said virtual path is 
completed in less than 250 milliseconds. 

7. (Original) The method of claim 4, wherein said first node receives said failure 
message packet. 

8. (Previously Presented) The method of claim 7, further comprising: 

(i) changing a state of said virtual path to restoring; 

(ii) identifying an adjacent node with required bandwidth for said 
virtual path; 

(iii) forwarding a resource request packet to said adjacent node with 
required bandwidth for said virtual path; 

(iv) waiting for a resource response packet for a predetermined time 
interval; and 

if said resource response packet is not received within said predetermined time 
interval, 

repeating steps (ii) - (iv) for a predefined threshold time. 

9. (Original) The method of claim 8, further comprising: 

if said resource response packet is not received within said predefined threshold 
time, 

generating a network alarm. 

10. (Original) The method of claim 8, further comprising: 

if said resource response packet is received with at least one error, 

waiting until responses to all resource request packets are received; and 

if said resource response packet is received with no errors, 

determining if a list of allocated ports in said resource response packet is 
valid. 
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11. (Original) The method of claim 10, further comprising: 
if said list of allocated port is valid, 

provisioning said virtual path on said allocated ports; and 
if said list of allocated ports is invalid, 
generating a network alarm. 

12. (Original) The method of claim 10, further comprising: 

if responses to all resource request packets are received with at least one error, 
generating a network alarm. 

13. (Previously Presented) The method of claim 9, wherein said predetermined time 
interval and predefined threshold time are dynamically calculated by said network. 

14. (Original) The method of claim 4, wherein one of said intermediate nodes 
receives said failure message. 

15. (Original) The method of claim 14, further comprising: 
changing a state of said virtual path to down; 

forwarding said failure message to adjacent nodes comprising said virtual path; 
initiating a timer for receiving a response to said forwarded failure message; 
if said timer expires before said response to said forwarded failure message is 
received, 

releasing resources of said virtual path; and 
if said response to said forwarded failure message is received before said timer 
expires, 

stopping said timer, and 

releasing resources of said virtual path. 

16. (Original) The method of claim 4, wherein said second node receives said failure 
message. 
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17. (Original) The method of claim 16, further comprising: 
acknowledging said failure message; 

changing a state of said virtual path to down; and 
releasing resources of said virtual path. 

18. (Previously Presented) The method of claim 8, wherein one of said intermediate 
nodes receives said resource request packet. 

19. (Original) The method of claim 18, further comprising: 
if said resource request packet includes at least one error, 

copying said resource request packet to a first resource response packet, 
decrementing a hop count field in said first resource response packet, 
adding an error code to said first resource response packet, and 
responding with said first resource response packet; and 
if said resource request packet includes no errors, 
allocating a resource to said virtual path, 
incrementing a hop count field in said resource request packet, 
forwarding said resource request packet to an adjacent node having a 

resource necessary to support said virtual path, and 
waiting for a second resource response packet from said adjacent node. 

20. (Previously Presented) The method of claim 19, further comprising: 
if said second resource response packet is not received within a second 

predetermined time interval, 

releasing said resource allocated to said virtual path, and 
forwarding a negative acknowledgment to said first node. 
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21 . (Previously Presented) The method of claim 19, further comprising: 

if said second resource response packet is received with at least one error, 
releasing said resource allocated to said virtual path, 
decrementing a hop count field in said second resource response packet, 
and 

forwarding said second resource response packet to said first node; and 
if said second resource response packet is received with no errors, 

determining if said second resource response packet includes a valid list of 
a plurality of ports. 

22. (Original) The method of claim 21, further comprising: 
if said list of said plurality of ports is invalid, 

releasing resources allocated to said virtual path, and 
forwarding a negative acknowledgement to said first node; 

if said list of said plurality of ports is valid, 

determining if said plurality of ports is available; 

if said plurality of ports is available, 

assigning said plurality of ports to said virtual path, and 
updating said virtual path information in a node database; 

if said plurality of ports is not available, 

adding an error code to said second resource response packet; 

decrementing a hop count field in said second resource response packet; and 

forwarding said second resource response packet to said first node. 

23. (Original) The method of claim 18, further comprising: 

if a state of said virtual path is one of 'restoring' and 'deleting', 

copying said resource request packet to said first resource response packet, 
decrementing said hop count field in said first resource response packet, 
adding an error code of to said first resource response packet, and 
responding with said first resource response packet. 

24. (Original) The method of claim 8, wherein said second node receives said 
resource request packet. 
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25. (Original) The method of claim 24, further comprising: 

if said resource request packet includes invalid information, 

copying said resource request packet to a third resource response packet, 
decrementing a hop count field in said third resource response packet, 
adding an error code to said third resource response packet, and 
responding with said third resource response packet; and 

if said resource request packet includes valid information, 

determining if a resource is available for said virtual path. 

26. (Original) The method of claim 25, further comprising: 
if said resource is available for said virtual path, 

copying said resource request packet to said third resource response 
packet, 

allocating said resource to said virtual path, 
updating said virtual path information in a node database, 
decrementing a hop count field in said third resource response packet, 
adding a list of a plurality of ports to said third resource response packet, 
and 

responding with said third resource response packet. 

27. (Original) The method of claim 25, further comprising: 
if said resource is not available for said virtual path, 

copying said resource request packet to said third resource response 
packet, 

decrementing said hop count field in said third resource response packet, 
adding an error code to said third resource response packet, and 
responding with said third resource response packet. 
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28. (Original) The method of claim 24, further comprising: 

if a state of said virtual path is one of 'restoring' and 'deleting', 

copying said resource request packet to said third resource response 
packet, 

decrementing said hop count field in said third resource response packet, 
adding an error code to said third resource response packet, and 
responding with said third resource response packet. 



29. (Previously Presented) A network element configured to restore a virtual path in 
an optical network, the network element comprising: 

a processor; 

a memory coupled to said processor; and 

a network interface coupled to said processor; said processor configured to 
identify a plurality of nodes with resources, wherein said nodes with 

resources are ones of said nodes having a resource necessary to 

support said virtual path, and 
identify an alternate physical path in response to said identifying said 

plurality of nodes with resources, said alternate physical path 

comprising ones of said nodes with resources. 

30. (Original) The network element of claim 29, wherein said processor is further 
configured to 

restore said virtual path using said alternate physical path. 

3 1 . (Original) The network element of claim 29, wherein said processor is further 
configured to 

configure said alternate physical path by establishing a communication 
connection between said ones of said nodes with resources; and 
provision said virtual path over said alternate physical path. 
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32. (Previously Presented) The network element of claim 29, wherein said processor 
is further configured to 

detect a failure in said virtual path; 

said detection of said failure is done by receiving a failure message packet; 
said virtual path is provisioned on a physical path between a first and a second 

node of said optical network; 
said optical network comprises said nodes; 

each one of said nodes is coupled to at least one other of said nodes by a plurality 
of optical links; 

said physical path between said first and said second node comprises a plurality of 

intermediate nodes; and 
each one of said nodes is coupled to at least one other of said nodes in a mesh 

topology. 

33. (Original) The network element of claim 32, wherein said processor is further 
configured to restore said virtual path in less than 2 seconds. 

34. (Original) The network element of claim 32, wherein said processor is further 
configured to restore said virtual path in less than 250 milliseconds. 

35. (Original) The method of claim 32, wherein 

said network element is configured as said first node; and 
said network element receives said failure message packet. 
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36. (Previously Presented) The network element of claim 35, wherein said processor 
is further configured to 

(i) change a state of said virtual path to restoring; 

(ii) identify an adjacent node with required bandwidth for said virtual 
path; 

(iii) forward a resource request packet to said adjacent node with 
required bandwidth for said virtual path; 

(iv) wait for a resource response packet for a predetermined time 
interval; and 

(v) if said resource response packet is not received within said 
predetermined time interval, 

repeat steps (ii) - (iv) for a predefined threshold time. 

37. (Original) The network element of claim 36, wherein said processor is further 
configured to 

if said resource response packet is not received within said predefined threshold 
time, 

generate a network alarm. 

38. (Original) The network element of claim 36, wherein said processor is further 
configured to 

if said resource response packet is received with at least one error, 

wait until responses to all resource request packets are received; and 

if said resource response packet is received with no errors, 

determine if a list of allocated ports in said resource response packet is 
valid. 

39. (Original) The network element of claim 38, wherein said processor is further 
configured to 

if said list of allocated port is valid, 

provision said virtual path on said allocated ports; and 
if said list of allocated ports is invalid, 

generate a network alarm. 
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40. (Original) The network element of claim 38, wherein said processor is further 
configured to 

if responses to all resource request packets are received with at least one error, 
generate a network alarm. 

41. (Previously Presented) The network element of claim 39, wherein said 
predetermined time interval and predefined threshold time are dynamically calculated by 
said network. 

42. (Previously Presented) The network element of claim 32, wherein 

said network element is configured as one of said intermediate nodes, and 
said network element receives said failure message packet. 

43. (Original) The network element of claim 42, wherein said processor is further 
configured to 

change a state of said virtual path to down; 

forward said failure message to adjacent nodes comprising said virtual path; 
initiate a timer for receiving a response to said forwarded failure message; 
if said timer expires before said response to said forwarded failure message is 
received, 

release resources of said virtual path; and 
if said response to said forwarded failure message is received before said timer 
expires, 

stop said timer, and 

release resources of said virtual path. 

44. (Original) The network element of claim 32, wherein said processor is further 
configured to 

said network element is configured as said second node, and 
said network element receives said failure message. 
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45. (Original) The network element of claim 44, wherein said processor is further 
configured to 

acknowledge said failure message; 

change a state of said virtual path to down; and 

release resources of said virtual path. 

46. (Original) The network element of claim 36, wherein 

said network element is configured as one of said intermediate nodes, and 
said network element receives said resource request packet. 

47. (Original) The network element of claim 46, wherein said processor is further 
configured to 

if said resource request packet includes at least one error, 

copy said resource request packet to a first resource response packet, 
decrement a hop count field in said first resource response packet, 
add an error code to said first resource response packet, and 
respond with said first resource response packet; and 

if said resource request packet includes no errors, 
allocate a resource to said virtual path, 
increment a hop count field in said resource request packet, 
forward said resource request packet to an adjacent node having a resource 

necessary to support said virtual path, and 
wait for a second resource response packet from said adjacent node. 

48. (Previously Presented) The network element of claim 47, wherein said processor 
is further configured to 

if said second resource response packet is not received within a second 
predetermined time interval, 

release said resource allocated to said virtual path, and 
forward a negative acknowledgment to said first node. 



Page 12 



Application No. : 09/89 1 ,022 



♦ 

PATENT 



49. (Original) The network element of claim 47, wherein said processor is further 
configured to 

if said second resource response packet is received with at least one error, 

release said resources allocated to said virtual path, 

decrement a hop count field in said second resource response packet, and 

forward said second resource response packet to said first node; and 
if said second resource response packet is received with no errors, 

determine if said second resource response packet includes a valid list of a 
plurality of ports. 

50. (Original) The network element of claim 49, wherein said processor is further 
configured to 

if said list of said plurality of ports is invalid, 

release resources allocated to said virtual path, and 
forward a negative acknowledgement to said first node; 

if said list of said plurality of ports is valid, 

determine if said plurality of ports is available; 

if said plurality of ports is available, 

assign said plurality of ports to said virtual path, and 
update said virtual path information in a node database; 

if said plurality of ports is not available, 

add an error code to said second resource response packet; 

decrement a hop count field in said second resource response packet; and 

forward said second resource response packet to said first node. 

5 1 . (Original) The network element of claim 46, wherein said processor is further 
configured to 

if a state of said virtual path is one of 'restoring' and 'deleting', 

copy said resource request packet to said first resource response packet, 
decrement said hop count field in said first resource response packet, 
add an error code of to said first resource response packet, and 
respond with said first resource response packet. 
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52. (Previously Presented) The network element of claim 36, wherein 
network element is configured as said second node, and 

said network element receives said resource request packet. 

53. (Original) The network element of claim 52, wherein said processor is further 
configured to 

if said resource request packet includes invalid information, 

copy said resource request packet to a third resource response packet, 
decrement a hop count field in said third resource response packet, 
add an error code to said third resource response packet, and 
respond with said third resource response packet; and 

if said resource request packet includes valid information, 

determine if a resource is available for said virtual path. 

54. (Original) The network element of claim 53, wherein said processor is further 
configured to 

if said resource is available for said virtual path, 

copy said resource request packet to said third resource response packet, 

allocate said resource to said virtual path, 

update said virtual path information in a node database, 

decrement a hop count field in said third resource response packet, 

add a list of a plurality of ports to said third resource response packet, and 

respond with said third resource response packet. 

55. (Original) The network element of claim 53, wherein said processor is further 
configured to 

if said resource is not available for said virtual path, 

copy said resource request packet to said third resource response packet, 
decrement said hop count field in said third resource response packet, 
add an error code to said third resource response packet, and 
respond with said third resource response packet. 
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56. (Original) The network element of claim 52, wherein said processor is further 
configured to 

if a state of said virtual path is one of 'restoring' and 'deleting', 

copy said resource request packet to said third resource response packet, 
decrement said hop count field in said third resource response packet, 
add an error code to said third resource response packet, and 
respond with said third resource response packet. 



57. (Previously Presented) A computer system for restoring a virtual path in an 
optical network, said computer system comprising: 

means for identifying a plurality of nodes with resources, wherein said nodes with 

resources are ones of said nodes having a resource necessary to support 

said virtual path; and 
means for identifying an alternate physical path in response to said identifying 

said plurality of nodes with resources, said alternate physical path 

comprising ones of said nodes with resources. 

58. (Original) The computer system of claim 57, further comprising: 
means for restoring said virtual path using said alternate physical path. 



59. (Original) The computer system of claim 57, wherein said restoring is done by 
means for configuring said alternate physical path by establishing a 

communication connection between said ones of said nodes with 
resources; and 

means for provisioning said virtual path over said alternate physical path. 
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60. (Previously Presented) The computer system of claim 58, further comprising: 
means for detecting a failure in said virtual path; 

said detection of said failure is done by receiving a failure message packet; 
said virtual path is provisioned on a physical path between a first and a second 

node of said optical network; 
said optical network comprises said nodes; 

each one of said nodes is coupled to at least one other of said nodes by a plurality 
of optical links; 

said physical path between said first and said second node comprises a plurality of 

intermediate nodes; and 
each one of said nodes is coupled to at least one other of said nodes in a mesh 

topology. 

61 . (Original) The computer system of claim 60, wherein said restoring of said 
virtual path is completed in less than 2 seconds. 

62. (Original) The computer system of claim 60, wherein said restoring of said 
virtual path is completed in less than 250 milliseconds. 

63 . (Original) The computer system of claim 60, wherein said first node receives said 
failure message packet. 
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64. (Previously Presented) The computer system of claim 63, further comprising: 

(i) means for changing a state of said virtual path to restoring; 

(ii) means for identifying an adjacent node with required bandwidth 
for said virtual path; 

(iii) means for forwarding a resource request packet to said adjacent 
node with required bandwidth for said virtual path; 

(iv) means for waiting for a resource response packet for a 
predetermined time interval; and 

means for repeating steps (ii) - (iv) for a predefined threshold time if said 

resource response packet is not received within said predetermined time 
interval. 

65. (Original) The computer system of claim 64, further comprising: 

means for generating a network alarm if said resource response packet is not 
received within said predefined threshold time. 

66. (Original) The computer system of claim 64, further comprising: 

means for waiting until responses to all resource request packets are received if 
said resource response packet is received with at least one error; and 

means for determining if a list of allocated ports in said resource response packet 
is valid if said resource response packet is received with no errors. 

67. (Original) The computer system of claim 66, further comprising: 

means for provisioning said virtual path on said allocated ports if said list of 

allocated port is valid; and 
means for generating a network alarm if said list of allocated ports is invalid. 

68. (Original) The computer system of claim 66, further comprising: 

means for generating a network alarm if responses to all resource request packets 
are received with at least one error. 
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69. (Previously Presented) The computer system of claim 65, wherein said 
predetermined time interval and predefined threshold time are dynamically calculated by 
said network. 

70. (Original) The computer system of claim 60, wherein one of said intermediate 
nodes receives said failure message. 

71. (Original) The computer system of claim 70, further comprising: 
means for changing a state of said virtual path to down; 

means for forwarding said failure message to adjacent nodes comprising said 
virtual path; 

means for initiating a timer for receiving a response to said forwarded failure 
message; 

means for releasing resources of said virtual path if said timer expires before said 
response to said forwarded failure message is received; 

means for stopping said timer if said response to said forwarded failure message 
is received before said timer expires; and 

means for releasing resources of said virtual path if said response to said 

forwarded failure message is received before said timer expires. 

72. (Original) The computer system of claim 60, wherein said second node receives 
said failure message. 

73. (Original) The computer system of claim 72, further comprising: 
means for acknowledging said failure message; 

means for changing a state of said virtual path to down; and 
means for releasing resources of said virtual path. 

74. (Original) The computer system of claim 64, wherein one of said intermediate 
nodes receives said resource request packet. 
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75. (Original) The computer system of claim 74, further comprising: 

means for copying said resource request packet to a first resource response packet 

if said resource request packet includes at least one error; 
means for decrementing a hop count field in said first resource response packet if 

said resource request packet includes at least one error; 
means for adding an error code to said first resource response packet if said 

resource request packet includes at least one error; 
means for responding with said first resource response packet if said resource 

request packet includes at least one error; 
means for allocating a resource to said virtual path if said resource request packet 

includes no errors; 

means for incrementing a hop count field in said resource request packet if said 

resource request packet includes no errors; 
means for forwarding said resource request packet to an adjacent node having a 

resource necessary to support said virtual path if said resource request 

packet includes no errors; and 
means for waiting for a second resource response packet from said adjacent node 

if said resource request packet includes no errors. 

76. (Previously Presented) The computer system of claim 75, further comprising: 
means for releasing said resource allocated to said virtual path if said second 

resource response packet is not received within a second predetermined 
time interval; and 

means for forwarding a negative acknowledgment to said first node if said second 
resource response packet is not received within said second predetermined 
time interval. 
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(Original) The computer system of claim 75, further comprising: 

means for releasing said resources allocated to said virtual path if said second 

resource response packet is received with at least one error; 
means for decrementing a hop count field in said second resource response 

packet if said second resource response packet is received with at least one 

error; 

means for forwarding said second resource response packet to said first node if 
said second resource response packet is received with at least one error; 
and 

means for determining if said second resource response packet includes a valid 
list of a plurality of ports if said second resource response packet is 
received with no errors. 

(Original) The computer system of claim 77, further comprising: 

means for releasing resources allocated to said virtual path if said list of said 

plurality of ports is invalid; 
means for forwarding a negative acknowledgement to said first node if said list of 

said plurality of ports is invalid; 
means for determining if said plurality of ports is available if said list of said 

plurality of ports is valid; 
means for assigning said plurality of ports to said virtual path if said plurality of 

ports is available; 

means for updating said virtual path information in a node database if said 

plurality of ports is available; 
means for adding an error code to said second resource response packet if said 

plurality of ports is not available; 
means for decrementing a hop count field in said second resource response 

packet; and 

means for forwarding said second resource response packet to said first node. 
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79. (Original) The computer system of claim 74, further comprising: 

means for copying said resource request packet to said first resource response 

packet if a state of said virtual path is one of 'restoring' and 'deleting'; 
means for decrementing said hop count field in said first resource response packet 

if a state of said virtual path is one of 'restoring' and 'deleting'; 
means for adding an error code of to said first resource response packet if a state 

of said virtual path is one of 'restoring' and 'deleting'; and 
means for responding with said first resource response packet if a state of said 

virtual path is one of 'restoring' and 'deleting'. 

80. (Original) The computer system of claim 64, wherein said second node receives 
said resource request packet. 

81 . (Original) The computer system of claim 80, further comprising: 

means for copying said resource request packet to a third resource response 

packet if said resource request packet includes invalid information; 
means for decrementing a hop count field in said third resource response packet if 

said resource request packet includes invalid information; 
means for adding an error code to said third resource response packet if said 

resource request packet includes invalid information; 
means for responding with said third resource response packet if said resource 

request packet includes invalid information; and 
means for determining if a resource is available for said virtual path if said 

resource request packet includes valid information. 

82. (Original) The computer system of claim 81, further comprising: 

means for copying said resource request packet to said third resource response 
packet if said resource is available for said virtual path; 

means for allocating said resource to said virtual path if said resource is available 
for said virtual path; 

means for updating said virtual path information in a node database if said 
resource is available for said virtual path; 
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means for decrementing a hop count field in said third resource response packet if 

said resource is available for said virtual path; 
means for adding a list of a plurality of ports to said third resource response 

packet if said resource is available for said virtual path; and 
means for responding with said third resource response packet. 

(Original) The computer system of claim 81, further comprising: 

means for copying said resource request packet to said third resource response 

packet if said resource is not available for said virtual path; 
means for decrementing said hop count field in said third resource response 

packet if said resource is not available for said virtual path; 
means for adding an error code to said third resource response packet if said 

resource is not available for said virtual path; and 
means for responding with said third resource response packet. 

(Original) The computer system of claim 80, further comprising: 

means for copying said resource request packet to said third resource response 

packet if a state of said virtual path is one of 'restoring' and 'deleting 5 ; 
means for decrementing said hop count field in said third resource response 

packet if a state of said virtual path is one of 'restoring' and 'deleting'; 
means for adding an error code to said third resource response packet if a state of 

said virtual path is one of 'restoring' and 'deleting'; and 
means for responding with said third resource response packet. 
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85. (Previously Presented) A computer program product for restoring a virtual path 
in an optical network, encoded in computer readable media, said program product 
comprising a set of instructions executable on a computer system, said set of instructions 
configured to 

identify a plurality of nodes with resources, wherein said nodes with resources are 
ones of said nodes having a resource necessary to support said virtual 
path; and 

identifying an alternate physical path in response to said identifying said plurality 
of nodes with resources, said alternate physical path comprising ones of 
said nodes with resources. 

86. (Original) The computer program product of claim 85, wherein said set of 
instructions is further configured to 

restore said virtual path using said alternate physical path. 

87. (Original) The computer program product of claim 85, wherein said set of 
instructions is further configured to 

configure said alternate physical path by establishing a communication 
connection between said ones of said nodes with resources; and 
provision said virtual path over said alternate physical path. 

88. (Previously Presented) The computer program product of claim 85, wherein said 
set of instructions is further configured to 

detect a failure in said virtual path; 

said detection of said failure is done by receiving a failure message packet; 
said virtual path is provisioned on a physical path between a first and a second 

node of said optical network; 
said optical network comprises said nodes; 

each one of said nodes is coupled to at least one other of said nodes by a plurality 
of optical links; 
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said physical path between said first and said second node comprises a plurality of 

intermediate nodes; and 
each one of said nodes is coupled to at least one other of said nodes in a mesh 

topology. 

89. (Original) The computer program product of claim 88, wherein said set of 
instructions is further configured to restore said virtual path in less than 2 seconds. 

90. (Original) The computer program product of claim 88, wherein said set of 
instructions is further configured to restore said virtual path in less than 250 milliseconds. 

91 . (Original) The method of claim 88, wherein said first node receives said failure 
message packet. 

92. (Previously Presented) The computer program product of claim 91, wherein said 
set of instructions is further configured to 

(i) change a state of said virtual path to restoring; 

(ii) identify an adjacent node with required bandwidth for said virtual 
path; 

(iii) forward a resource request packet to said adjacent node with 
required bandwidth for said virtual path; 

(iv) wait for a resource response packet for a predetermined time 
interval; and 

(v) if said resource response packet is not received within said 
predetermined time interval, 

repeat steps (ii) - (iv) for a predefined threshold time. 

93. (Original) The computer program product of claim 92, wherein said set of 
instructions is further configured to 

if said resource response packet is not received within said predefined threshold 
time, 

generate a network alarm. 
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94. (Previously Presented) The computer program product of claim 92, wherein said 
set of instructions is further configured to 

if said resource response packet is received with at least one error, 

wait until responses to all resource request packets are received; and 

if said resource response packet is received with no errors, 

determine if a list of allocated ports in said resource response packet is 
valid. 

95. (Original) The computer program product of claim 94, wherein said set of 
instructions is further configured to 

if said list of allocated port is valid, 

provision said virtual path on said allocated ports; and 
if said list of allocated ports is invalid, 

generate a network alarm. 

96. (Original) The computer program product of claim 93, wherein said set of 
instructions is further configured to 

if responses to all resource request packets are received with at least one error, 
generate a network alarm. 

97. (Previously Presented) The computer program product of claim 92, wherein said 
predetermined time interval and predefined threshold time are dynamically calculated by 
said network. 

98. (Original) The computer program product of claim 88, wherein one of said 
intermediate nodes receives said failure message. 

99. (Original) The computer program product of claim 88, wherein said set of 
instructions is further configured to 

change a state of said virtual path to down; 

forward said failure message to adjacent nodes comprising said virtual path; 
initiate a timer for receiving a response to said forwarded failure message; 
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if said timer expires before said response to said forwarded failure message is 
received, 

release resources of said virtual path; and 
if said response to said forwarded failure message is received before said timer 
expires, 

stop said timer, and 

release resources of said virtual path. 

100. (Original) The computer program product of claim 88, wherein said second node 
receives said failure message. 

101. (Original) The computer program product of claim 100, wherein said set of 
instructions is further configured to 

acknowledge said failure message; 

change a state of said virtual path to down; and 

release resources of said virtual path. 

102. (Original) The computer program product of claim 92, wherein one of said 
intermediate nodes receives said resource request packet. 

103. (Original) The computer program product of claim 92, wherein said set of 
instructions is further configured to 

if said resource request packet includes at least one error, 

copy said resource request packet to a first resource response packet, 
decrement a hop count field in said first resource response packet, 
add an error code to said first resource response packet, and 
respond with said first resource response packet; and 

if said resource request packet includes no errors, 
allocate a resource to said virtual path, 
increment a hop count field in said resource request packet, 
forward said resource request packet to an adjacent node having a resource 

necessary to support said virtual path, and 
wait for a second resource response packet from said adjacent node. 
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104. (Previously Presented) The computer program product of claim 103, wherein said 
set of instructions is further configured to 

if said second resource response packet is not received within a second 
predetermined time interval, 

release said resource allocated to said virtual path, and 
forward a negative acknowledgment to said first node. 

105. (Original) The computer program product of claim 103, wherein said set of 
instructions is further configured to 

if said second resource response packet is received with at least one error, 
release said resources allocated to said virtual path, 
decrement a hop count field in said second resource response packet, and 
forward said second resource response packet to said first node; and 

if said second resource response packet is received with no errors, 

determine if said second resource response packet includes a valid list of a 
plurality of ports. 

106. (Original) The computer program product of claim 105, wherein said set of 
instructions is further configured to 

if said list of said plurality of ports is invalid, 

release resources allocated to said virtual path, and 
forward a negative acknowledgement to said first node; 

if said list of said plurality of ports is valid, 

determine if said plurality of ports is available; 

if said plurality of ports is available, 

assign said plurality of ports to said virtual path, and 
update said virtual path information in a node database; 

if said plurality of ports is not available, 

add an error code to said second resource response packet; 

decrement a hop count field in said second resource response packet; and 

forward said second resource response packet to said first node. 
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107. (Original) The computer program product of claim 102, wherein said set of 
instructions is further configured to 

if a state of said virtual path is one of 'restoring' and 'deleting', 

copy said resource request packet to said first resource response packet, 
decrement said hop count field in said first resource response packet, 
add an error code of to said first resource response packet, and 
respond with said first resource response packet. 

108. (Original) The computer program product of claim 92, wherein said second node 
receives said resource request packet. 

109. (Original) The computer program product of claim 108, wherein said set of 
instructions is further configured to 

if said resource request packet includes invalid information, 

copy said resource request packet to a third resource response packet, 
decrement a hop count field in said third resource response packet, 
add an error code to said third resource response packet, and 
respond with said third resource response packet; and 

if said resource request packet includes valid information, 

determine if a resource is available for said virtual path. 

110. (Original) The computer program product of claim 109, wherein said set of 
instructions is further configured to 

if said resource is available for said virtual path, 

copy said resource request packet to said third resource response packet, 

allocate said resource to said virtual path, 

update said virtual path information in a node database, 

decrement a hop count field in said third resource response packet, 

add a list of a plurality of ports to said third resource response packet, and 

respond with said third resource response packet. 
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111. (Original) The computer program product of claim 108, wherein said set of 
instructions is further configured to 

if said resource is not available for said virtual path, 

copy said resource request packet to said third resource response packet, 
decrement said hop count field in said third resource response packet, 
add an error code to said third resource response packet, and 
respond with said third resource response packet. 

112. (Previously Presented) The computer program product of claim 108, wherein said 
set of instructions is further configured to 

if a state of said virtual path is one of 'restoring' and 'deleting', 

copy said resource request packet to said third resource response packet, 
decrement said hop count field in said third resource response packet, 
add an error code to said third resource response packet, and 
respond with said third resource response packet. 



113. (Previously Presented) A network element configured to restore a virtual path in 
an optical network, the network element comprising: 
a processor; 

a memory coupled to said processor; and 

a network interface coupled to said processor; said processor configured to 
identify a plurality of nodes with resources, wherein said nodes with 

resources are ones of said nodes having a resource necessary to 

support said virtual path, 
identify an alternate physical path, said alternate physical path comprising 

ones of said nodes with resources, 
detect a failure in said virtual path, 
change a state of said virtual path to restoring, 

(i) identify an adjacent node with required bandwidth for said virtual 
path, 

(ii) forward a resource request packet to said adjacent node with 
required bandwidth for said virtual path, 
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(iii) wait for a resource response packet for a predetermined time 
interval, and 

if said resource response packet is not received within said predetermined 
time interval, repeat steps (i) — (iii) for a predefined threshold time; 

wherein, 

said detection of said failure is done by receiving a failure message packet; 
said virtual path is provisioned on a physical path between a first and a second 

node of said optical network; 
said optical network comprises said nodes; 

each one of said nodes is coupled to at least one other of said nodes by a plurality 
of optical links; 

said physical path between said first and said second node comprises a plurality of 

intermediate nodes; 
each one of said nodes is coupled to at least one other of said nodes in a mesh 

topology; 

said network element is configured as said first node; and 
said network element receives said failure message packet. 
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